using System;
using System.Collections.Generic;
using System.Text;
using System.Data;
using System.Data.SqlClient;
using database;
using objetos;

namespace dados
{
	#region TB_ESTOQUE_MOVIMENTO
	/// <summary>
	/// This object represents the properties and methods of a TB_ESTOQUE_MOVIMENTO.
	/// </summary>
	public class DAL_TB_ESTOQUE_MOVIMENTO
	{		
	
		/// <summary>
		/// Incluir via aplicacao
		/// </summary>	
		public int Incluir(OBJ_TB_ESTOQUE_MOVIMENTO obj)
		{
			try
			{
				DAO_DATABASE db = new DAO_DATABASE();
				DataSet ds = new DataSet();
				List<string> lista = new List<string>();		
	
				db.CreateParameter("@id_empresa", SqlDbType.Int, obj.id_empresa);				
				lista.Add("@id_empresa");				
				db.CreateParameter("@id_tipo_movimento", SqlDbType.Int, obj.id_tipo_movimento);				
				lista.Add("@id_tipo_movimento");				
				db.CreateParameter("@sigla_movimento", SqlDbType.Char, obj.sigla_movimento);				
				lista.Add("@sigla_movimento");
                db.CreateParameter("@tipo_documento", SqlDbType.Char, obj.tipo_documento);
                lista.Add("@tipo_documento");
                db.CreateParameter("@num_documento", SqlDbType.VarChar, obj.num_documento);
                lista.Add("@num_documento");			
				db.CreateParameter("@id_produto", SqlDbType.Int, obj.id_produto);				
				lista.Add("@id_produto");				
				db.CreateParameter("@qtd_entrada", SqlDbType.Decimal, obj.qtd_entrada);				
				lista.Add("@qtd_entrada");				
				db.CreateParameter("@qtd_saida", SqlDbType.Decimal, obj.qtd_saida);				
				lista.Add("@qtd_saida");				
				db.CreateParameter("@valor_compra", SqlDbType.Decimal, obj.valor_compra);				
				lista.Add("@valor_compra");				
				db.CreateParameter("@valor_venda", SqlDbType.Decimal, obj.valor_venda);				
				lista.Add("@valor_venda");				
				db.CreateParameter("@id_usuario", SqlDbType.Int, obj.id_usuario);				
				lista.Add("@id_usuario");				
				db.CreateParameter("@dt_atualizacao", SqlDbType.DateTime, obj.dt_atualizacao);				
				lista.Add("@dt_atualizacao");				
	
				string query = String.Format("Insert Into tb_estoque_movimento ({0}) Values ({1}); SELECT SCOPE_IDENTITY()",  string.Join(",",lista.ToArray()).ToString().Replace("@", ""), string.Join(",",lista.ToArray()).ToString());
				ds = db.ExecuteQuery(query);
				
				return Convert.ToInt32(ds.Tables[0].Rows[0][0].ToString());
			}
			catch (Exception)
       		{
            	throw;
        	}
		}
		
		/// <summary>
		/// Update via aplicacao
		/// </summary>			
		public void Alterar(OBJ_TB_ESTOQUE_MOVIMENTO obj)
		{
			try
			{
				DAO_DATABASE db = new DAO_DATABASE();
				List<string> lista = new List<string>();
	
				db.CreateParameter("@id", SqlDbType.Int, obj.id);
				
	
				db.CreateParameter("@id_empresa", SqlDbType.Int, obj.id_empresa);
				lista.Add("id_empresa = @id_empresa");
				db.CreateParameter("@id_tipo_movimento", SqlDbType.Int, obj.id_tipo_movimento);
				lista.Add("id_tipo_movimento = @id_tipo_movimento");
				db.CreateParameter("@sigla_movimento", SqlDbType.Char, obj.sigla_movimento);
                lista.Add("num_documento = @num_documento");
                db.CreateParameter("@num_documento", SqlDbType.VarChar, obj.num_documento);
                lista.Add("tipo_documento = @tipo_documento");
                db.CreateParameter("@tipo_documento", SqlDbType.Char, obj.tipo_documento);
				lista.Add("sigla_movimento = @sigla_movimento");
				db.CreateParameter("@id_produto", SqlDbType.Int, obj.id_produto);
				lista.Add("id_produto = @id_produto");
				db.CreateParameter("@qtd_entrada", SqlDbType.Decimal, obj.qtd_entrada);
				lista.Add("qtd_entrada = @qtd_entrada");
				db.CreateParameter("@qtd_saida", SqlDbType.Decimal, obj.qtd_saida);
				lista.Add("qtd_saida = @qtd_saida");
				db.CreateParameter("@valor_compra", SqlDbType.Decimal, obj.valor_compra);
				lista.Add("valor_compra = @valor_compra");
				db.CreateParameter("@valor_venda", SqlDbType.Decimal, obj.valor_venda);
				lista.Add("valor_venda = @valor_venda");
				db.CreateParameter("@id_usuario", SqlDbType.Int, obj.id_usuario);
				lista.Add("id_usuario = @id_usuario");
				db.CreateParameter("@dt_atualizacao", SqlDbType.DateTime, obj.dt_atualizacao);
				lista.Add("dt_atualizacao = @dt_atualizacao");
	
				string query = String.Format("Update TB_ESTOQUE_MOVIMENTO Set {0} Where id = @id", string.Join(",",lista.ToArray()).ToString());
				db.ExecuteQuery(query);
			}
			catch (Exception)
       		{
            	throw;
        	}
		}	
		
		/// <summary>
		/// Delete viaaplicacao
		/// </summary>	
		public void Excluir(OBJ_TB_ESTOQUE_MOVIMENTO obj)
		{
			try
			{
				DAO_DATABASE db = new DAO_DATABASE();
				StringBuilder queryParameters = new StringBuilder();
				db.CreateParameter("@id", SqlDbType.Int, obj.id);                
				string query = "Delete tb_estoque_movimento Where id = @id ";			
				db.ExecuteQuery(query);
			}
			catch (Exception)
       		{
            	throw;
        	}
		}
	
	
		/// <summary>
		/// Lista objeto
		/// </summary>						
		public List<OBJ_TB_ESTOQUE_MOVIMENTO> SelecionarLista()
    	{
        	try
        	{
				DAO_DATABASE db = new DAO_DATABASE();
				List<OBJ_TB_ESTOQUE_MOVIMENTO> lista = new List<OBJ_TB_ESTOQUE_MOVIMENTO>();
				OBJ_TB_ESTOQUE_MOVIMENTO obj = null;
				DataTable dt = new DataTable();
				DataSet ds = new DataSet();
				StringBuilder sb = new StringBuilder();
				sb.Append("Select * from  TB_ESTOQUE_MOVIMENTO ");
        
	            ds = db.ExecuteQuery(sb.ToString());
				
				if(!db.DataSetIsEmpty(ds))
				{
					dt = ds.Tables[0];
					
					foreach (DataRow dr in dt.Rows)
					{											
						obj = new OBJ_TB_ESTOQUE_MOVIMENTO();
						Set(obj,dr);
						lista.Add(obj);
		
					}
				}
				return lista;
        	}
        	catch (Exception)
       		{
            	throw;
        	}

    	}
		
		/// <summary>
		/// Set Objeto
		/// </summary>	
		private void Set(OBJ_TB_ESTOQUE_MOVIMENTO obj,DataRow dr)
		{
			obj.id = Convert.ToInt32(dr["id"]);						
			obj.id_empresa = Convert.ToInt32(dr["id_empresa"].ToString()) ;	
			obj.id_tipo_movimento = Convert.ToInt32(dr["id_tipo_movimento"].ToString()) ;	
			obj.sigla_movimento = dr["sigla_movimento"] == DBNull.Value ?  string.Empty : dr["sigla_movimento"].ToString() ;
            obj.tipo_documento = dr["tipo_documento"] == DBNull.Value ? string.Empty : dr["tipo_documento"].ToString();
            obj.num_documento = dr["num_documento"] == DBNull.Value ? string.Empty : dr["num_documento"].ToString();	
			obj.id_produto = Convert.ToInt32(dr["id_produto"].ToString()) ;	
			obj.qtd_entrada = dr["qtd_entrada"] == DBNull.Value ?  0 : Convert.ToDecimal(dr["qtd_entrada"].ToString()) ;
			obj.qtd_saida = dr["qtd_saida"] == DBNull.Value ?  0 : Convert.ToDecimal(dr["qtd_saida"].ToString()) ;
			obj.valor_compra = dr["valor_compra"] == DBNull.Value ?  0 : Convert.ToDecimal(dr["valor_compra"].ToString()) ;
			obj.valor_venda = dr["valor_venda"] == DBNull.Value ?  0 : Convert.ToDecimal(dr["valor_venda"].ToString()) ;
			obj.id_usuario = Convert.ToInt32(dr["id_usuario"].ToString()) ;	
			obj.dt_atualizacao = dr["dt_atualizacao"] == DBNull.Value ? (DateTime?)null :  Convert.ToDateTime(dr["dt_atualizacao"].ToString()) ;						
			
		}						
				
		/// <summary>
		/// Selecionar Objeto Por ID
		/// </summary>	
		public OBJ_TB_ESTOQUE_MOVIMENTO SelecionarObjetoPorId(int id)
		{
			try
			{
				DAO_DATABASE db = new DAO_DATABASE();
				OBJ_TB_ESTOQUE_MOVIMENTO obj = new OBJ_TB_ESTOQUE_MOVIMENTO();
				DataSet ds = new DataSet();				
				DataTable dt = new DataTable();
				
				db.CreateParameter("@id", SqlDbType.Int, id);
				StringBuilder sb = new StringBuilder();
				sb.Append("SELECT * FROM tb_estoque_movimento  Where id = @id");
				ds = db.ExecuteQuery(sb.ToString());				
				
				if(!db.DataSetIsEmpty(ds))
				{
					dt = ds.Tables[0];
					
					foreach (DataRow dr in dt.Rows)
                	{
						obj = new OBJ_TB_ESTOQUE_MOVIMENTO();
						Set(obj,dr);																			
					}
					return obj;
					
				}
				else
				{
					return null;	
				}			
			}
			catch (Exception)
       		{
            	throw;
        	}
			
		}
					
		
		
		/// <summary>
		/// Lista objeto Parametro Where OrderBy
		/// </summary>							
		public List<OBJ_TB_ESTOQUE_MOVIMENTO> SelecionarLista(String Where, String OrderBy)
    	{
        	try
        	{
				DAO_DATABASE db = new DAO_DATABASE();
				OBJ_TB_ESTOQUE_MOVIMENTO obj = null;
				DataSet ds = new DataSet();
				DataTable dt = new DataTable();
				List<OBJ_TB_ESTOQUE_MOVIMENTO> lista = new List<OBJ_TB_ESTOQUE_MOVIMENTO>();
				
				StringBuilder sb = new StringBuilder();
				db.CreateParameter("@Where",SqlDbType.VarChar, Where );
				db.CreateParameter("@OrderBy", SqlDbType.VarChar, OrderBy );				
				
				sb.Append("SELECT * ");
				sb.Append(" FROM TB_ESTOQUE_MOVIMENTO");
				if(Where != string.Empty)				
				sb.Append(string.Format(" Where {0} ",Where));
				if(OrderBy != string.Empty)
				sb.Append(string.Format(" Order by {0}",OrderBy));
				
				ds = db.ExecuteQuery(sb.ToString());
				
				if(!db.DataSetIsEmpty(ds))
				{
					dt = ds.Tables[0];
					foreach (DataRow dr in dt.Rows)
					{						
						obj = new OBJ_TB_ESTOQUE_MOVIMENTO();
						Set(obj,dr);			
						lista.Add(obj);
					}
				}
				return lista;
        	}
        	catch (Exception)
       		{
            	throw;
        	}

    	}

		
		public DataSet Selecionar(String Where, String OrderBy, int PageIndex, int PageSize )
		{
				DAO_DATABASE db = new DAO_DATABASE();
				DataSet ds = new DataSet();
				
				StringBuilder sb = new StringBuilder();
				
				PageIndex = PageSize * PageIndex;
            	PageSize =  PageIndex + PageSize;
				
		      	if (OrderBy == string.Empty) OrderBy = "tb_estoque_movimento.id";

            	sb.Append("SELECT * FROM ");
            	sb.Append(string.Format(" (SELECT ROW_NUMBER() OVER (ORDER BY {0}) AS RowNumber,",OrderBy));
           		sb.Append(" * FROM   tb_estoque_movimento ");
				if (Where != string.Empty)
				{
					sb.Append(string.Format(" WHERE {0}", Where));
				}
				sb.Append(" ) query  ");
				sb.Append(string.Format(" WHERE RowNumber BETWEEN {0} + 1 and {1}; ",PageIndex,PageSize));

            	sb.Append("SELECT count(*) FROM tb_estoque_movimento");
				if (Where != string.Empty)
				{
					sb.Append(string.Format(" WHERE {0}", Where));
				}
				ds = db.ExecuteQuery(sb.ToString());
				
				if (!db.DataSetIsEmpty(ds))
            	{
                publico.PUB_PAGINACAO.CalcularTotalDePaginas(Convert.ToDecimal(ds.Tables[1].Rows[0][0].ToString()));
            	}

				
            	return ds;
								
		}
				
								
		public DataSet Selecionar(String Where, String OrderBy)
        {
            DAO_DATABASE db = new DAO_DATABASE();
            DataSet ds = new DataSet();
            StringBuilder sb = new StringBuilder();

            sb.Append("Select * from  TB_ESTOQUE_MOVIMENTO ");
           if (Where != string.Empty)
            {
                db.CreateParameter("@Where", SqlDbType.VarChar, Where);
                sb.Append(string.Format(" Where  {0}",Where));
            }

            if (OrderBy != string.Empty)
            {
                db.CreateParameter("@OrderBy", SqlDbType.VarChar, OrderBy);
                sb.Append(string.Format(" Order By {0}", OrderBy));
            }

            ds = db.ExecuteQuery(sb.ToString());
            return ds;
        }		
		
        public int Saldo(int id_empresa, int id_produto)
        {

            try
            {
                DAO_DATABASE db = new DAO_DATABASE();
                DataSet ds = new DataSet();
                StringBuilder sb = new StringBuilder();
                int saldo = 0;
                sb.Append("select isnull(SUM(qtd_entrada) - SUM(qtd_saida),0) from tb_estoque_movimento  ");
                sb.Append(" where id_empresa = @id_empresa and id_produto = @id_produto ");
                ds = db.ExecuteQuery(sb.ToString());

                if (!db.DataSetIsEmpty(ds))
                {
                    saldo = Convert.ToInt32(ds.Tables[0].Rows[0][0].ToString());
                }

                return saldo;
            }
            catch (Exception)
            {
                
                throw;
            }
            

        }

		public DataSet Selecionar()
        {
            DAO_DATABASE db = new DAO_DATABASE();
            DataSet ds = new DataSet();
            StringBuilder sb = new StringBuilder();

            sb.Append("Select * from  TB_ESTOQUE_MOVIMENTO Order By id");            
            ds = db.ExecuteQuery(sb.ToString());
            return ds;
        }		
		
		
		public DataSet ListaCampos()
        {

            DAO_DATABASE db = new DAO_DATABASE();
            DataSet ds = new DataSet();
            StringBuilder sb = new StringBuilder();
            sb.Append("SELECT TABLE_NAME, ORDINAL_POSITION, ");
            sb.Append(" COLUMN_NAME, DATA_TYPE, IS_NULLABLE ");
            sb.Append(" FROM INFORMATION_SCHEMA.COLUMNS");
            sb.Append(" WHERE TABLE_NAME = 'tb_estoque_movimento'");
            ds = db.ExecuteQuery(sb.ToString());

            return ds;

        }

		public DataSet DropdownList()
        {
            DAO_DATABASE db = new DAO_DATABASE();
            DataSet ds = new DataSet();
            StringBuilder sb = new StringBuilder();
			sb.Append("SELECT ");
			sb.Append(" id ");
				sb.Append(", id_empresa ");  				
				sb.Append(", id_tipo_movimento ");  				
				sb.Append(", sigla_movimento ");  				
			sb.Append(" FROM tb_estoque_movimento ");           
			sb.Append(" ORDER BY id_empresa ");
            ds = db.ExecuteQuery(sb.ToString());

            // ds = db.ExecuteProcedure("USP_TB_ESTOQUE_MOVIMENTO_DROPDOWNLIST");  
            return ds;
        }

        public DataSet DropdownList(String Where)
        {
            DAO_DATABASE db = new DAO_DATABASE();
            DataSet ds = new DataSet();
            StringBuilder sb = new StringBuilder();
            db.CreateParameter("@Where", SqlDbType.VarChar, Where);
			sb.Append("SELECT ");
			sb.Append(" id ");
			
			
			sb.Append(", id_empresa ");  				
			
			
			sb.Append(", id_tipo_movimento ");  				
			
			
			sb.Append(", sigla_movimento ");  				
			sb.Append(" FROM tb_estoque_movimento ");
			sb.Append(string.Format(" WHERE {0} ",Where));
			sb.Append(" ORDER BY id_empresa ");
            ds = db.ExecuteQuery(sb.ToString());

            // ds = db.ExecuteProcedure("USP_TB_ESTOQUE_MOVIMENTO_DROPDOWNLIST");
            return ds;
        }
		
		  public DataSet DropdownList(String Where, String OrderBy)
        {
            DAO_DATABASE db = new DAO_DATABASE();
            DataSet ds = new DataSet();
            StringBuilder sb = new StringBuilder();
            db.CreateParameter("@Where", SqlDbType.VarChar, Where);
			sb.Append("SELECT ");
			sb.Append(" id ");
			sb.Append(", id_empresa ");  				
			sb.Append(", id_tipo_movimento ");  				
			sb.Append(", sigla_movimento ");  				
			sb.Append(" FROM tb_estoque_movimento ");
			sb.Append(string.Format(" WHERE {0} ORDER BY {1}",Where,OrderBy));			
            ds = db.ExecuteQuery(sb.ToString());

            // ds = db.ExecuteProcedure("USP_TB_ESTOQUE_MOVIMENTO_DROPDOWNLIST");
            return ds;
        }

	}
	#endregion
}

